// pages/search/search.js
import request from "../../utils/request";

let isSend = false; // 函数截流使用
Page({

  /**
   * 页面的初始数据
   */
  data: {
    placeholderContent: '',  // placeholder的内容
    hotList: [], // 排行榜数据
    serachContent: '', // 用户输入的搜索值
    serachList: [], // 搜索的关键数据
    historyList: [], // 搜索历史数据
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {
    this.getInitData();
    this.getSearchHistory();
  },

  // 初始化数据
  async getInitData(){
    let placeholderData = await request('/search/default')
    let hotListData  = await request('/search/hot/detail')
    this.setData({
      placeholderContent: placeholderData.data.showKeyword,
      hotList: hotListData.data
    })
  },

  // 获取本地历史记录
  getSearchHistory(){
    let historyList = wx.getStorageSync('searchContent');
    if(historyList){
      this.setData({
        historyList
      })
    }
  },

  // 表单项内容改变
  handleInputChange(event){
    this.setData({
      serachContent: event.detail.value.trim()
    })

    if(isSend){
      return
    }
    isSend = true;
    this.getSerachListData();
    // 函数截流
    setTimeout(  () => {
      isSend = false;
    }, 300 )
  },
  
  // 获取搜索数据
  async getSerachListData(){
    if(! this.data.serachContent){
      this.setData({
        serachList: []
      })
      return;
    }
    let {serachContent, historyList} = this.data
    // 发请求获取数据
    let serachListData = await request('/search', {keywords: serachContent, limit: 10})
    this.setData({
      serachList: serachListData.result.songs
    })

    // 将搜索的关键字添加到搜索历史记录中
    
    if(historyList.indexOf(serachContent) !== -1)
      historyList.splice(historyList.indexOf(serachContent),1)

    historyList.unshift(serachContent);
    
    this.setData({
      historyList
    })

    wx.setStorageSync('searchContent', historyList);
  },

  // 清空搜索内容
  clearSearchContent(){
    this.setData({
      serachContent: '',
      serachList: []
    })
  },

  // 清除历史记录
  deleteSearchHistory(){
    wx.showModal({
      content: '确认是否要删除历史搜索记录？',
      success: (res) => {
        if(res.confirm) {
          // 移除页面数据
          this.setData({
            historyList: []
          })
          // 移除本地缓存
           wx.removeStorageSync('searchContent');
        }
      }
    })
  },
   
  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})